## 7.11 Register files

A **three-state buffer** is a component that outputs y = b if input a is 1, and outputs Z if a is 0. Z represents an electrical situar **high impedance**. A wire with Z is akin to no wire. As such, three-state buffers support efficient combining of multiple wires will be seen when introducing register files below. Of course, only one connected wire can have a non-Z (0 or 1) value, else collide. Further details on three-state buffer and high impedance are beyond this material's scope.



## PARTICIPATION ACTIVITY

7.11.1: Three-state buffer.

Given a three-state buffer with control input a, data input b, and data output y.

- 1) If a = 1 and b = 1, then y = ?
  - 0
  - **O** 'Z'
- 2) If a = 1 and b = 0, then y = ?

  - 0 0
- 3) If a = 0 and b = 0, then y = ?

7.11. Register files

O 0

A three-state buffer is more commonly called a **tri-state buffer**, but that name is trademarked. The term *three-state driver* (consists also used.

An NxM **register file** efficiently implements access to N M-bit registers. A 16x32 register file has 16 registers, each 32 bits values having 512 (16 times 32) wires connecting with those registers for loads, a register file consolidates loads through one 32-course, the tradeoff is that only one register can be loaded at a time, as indicated by a 4-bit address input. Loading a register file is known as a **write** operation. The data input, address input, and load enable input for writing are together called a **write** a register file consolidates read wires into a single 32-bit data output, 4-bit address input, and enable input, forming a **read** port may use three-state buffers to efficiently connect the data wires.





1) A 32x8 register file consists of \_\_\_\_\_ registers.
O 8
O 32
O 40
2) The write address, write enable control, and write data are collectively known as what?
O Write port

7.11.3: Register file.

**PARTICIPATION** 

O Read port

load, a register.

O True

O Write decoder

3) W\_en must be set to 1 to write to, or

**ACTIVITY** 

| O False                                                                                                                                                                      |   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| 4) Given a 32x8 register file, how many bits is W_addr?                                                                                                                      | _ |
| <b>O</b> 2                                                                                                                                                                   |   |
| <b>O</b> 3                                                                                                                                                                   |   |
| <b>O</b> 5                                                                                                                                                                   |   |
| <ul> <li>5) Assuming a register file with one write port and two read ports, write and read operations can occur simultaneously.</li> <li>O True</li> <li>O False</li> </ul> |   |
| <ul> <li>Assuming a register file with one write port and two read ports, two read operations can occur simultaneously.</li> <li>True</li> </ul>                             |   |
| O False                                                                                                                                                                      |   |
| 1 4100                                                                                                                                                                       |   |

PARTICIPATION ACTIVITY

7.11.4: Register files: Writing.

For the given values of W\_addr, W\_en, and W\_data, indicate the register file's contents in a given clock cycle.



PARTICIPATION ACTIVITY

7.11.5: Register files: Writing and reading.

Assume a 4x32 register file with one read port and one write port. Determine R\_data's value at each indicated time. If appropriate, type: Z.



| - | ١ ١ | /  | ١  |
|---|-----|----|----|
|   | ۱)  | 12 | ıι |
|   | ' / | 10 | λJ |

**Check** Show answer

2) (b)

**Check** Show answer

3) (c)

Check Show answer

4) (d)

| Check Show and 5) (e)    | swer                                | ~ |
|--------------------------|-------------------------------------|---|
| Check Show and           | swer                                |   |
| challenge 7.11.1: Regist | ter file writing and reading.       |   |
| Start                    |                                     | 1 |
|                          | Update the values after rising clk. | 2 |
|                          | 74                                  | 3 |
| 0                        |                                     | 4 |
| 1                        | 87                                  | 5 |
| 0                        | 99                                  | _ |
| 0                        | 94                                  | 6 |
| 0                        | 99                                  | 7 |
| 0                        | 99                                  | 8 |
|                          |                                     |   |

1 2 3 4 5 6 7 8

Check Next

Provide feedback on this section